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The bus architecture of the MEK6800D2 
Kit Microcomputer provides straight- 
forward design options for memory or 
I/O port expansion. This note outlines 
techniques for interfacing an 8K or 16K 
memory array with the kit. A technique 
is also outlined whereby a data terminal- 
based ROM monitor such as MINIBUG 
may co-reside with the basic kit ROM 
JBUG Monitor. The resulting two- 
monitor system allows the user to switch 
between either the JBUG I/O port or 
the MINIBUG I/O port for moving data 
to and from RAM. 
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MEK6800D2 MICROCOMPUTER KIT 
SYSTEM EXPANSION TECHNIQUES 



INTRODUCTION 

The Motorola MEK6800D2 kit microcomputer sys- 
tem (hereafter referred to as MEK/D2) is a complete 
computer requiring only a +5 V power supply to begin 
microprocessor evaluation. It features a hexadecimal 
keyboard for data and command entry and seven- 
segment LED array for data display. In addition, the 
MEK/D2 provides an audio cassette I/O data transfer 
capability. Figure 1 presents a functional block diagram 
of the basic system. The intent of this note is to describe 
some useful system expansion techniques which exploit 
the architecture of MEK/D2 computer. This note is 
intended to supplement the information provided in the 
MEK/D2 manual and is divided into sections which 
discuss memory expansion, data I/O port expansion 
and expanded system application considerations. 

Off-board memory expansion involves only minor 
changes in addressing and control logic plus certain 
elementary control-handshake logic to support both 
dynamic memory arrays and provide MPU control for 
slow memory arrays. 

The inclusion of an I/O port to add data terminal 
communication in addition to the keyboard module 
function is accomplished by inserting control logic 
which converts MEK/D2 into a dual-monitor micro- 
computer system. This modification allows the basic 
MEK/D2 JBUG monitor ROM and its ACIA to co- 
reside with a MINIBUG ROM/ACIA combination. 
The JBUG-ROM/ACIA pair support keyboard and 
audio cassette data I/O transfer while MINIBUG, along 
with its ACIA, supports RS-232 or current loop-con- 
figured data terminals. Each ROM/ACIA pair may be 
manually initialized or software-accessed from the user 
program. 

The capability to select, initialize, or address loca- 
tions in either monitor ROM at will provides useful 
system application benefits. These include moving data 
between various storage media, directly addressing 
proven subroutines in either ROM from user program 
and manually selecting either monitor as desired to 
exploit the most useful commands of each during a soft- 
ware or system development phase. These modifications 
convert the MEK/D2 into a powerful software develop- 
ment tool. 



RANDOM ACCESS MEMORY EXPANSION 
Functional Design 

The basic MEK/D2 Microcomputer Module provides 
for a maximum of 512 bytes of On-Board static RAM. 
Expansion for additional memory is accomplished by 
providing address and data bus buffers as well as some 
Off-Board control logic. 

Figure 2 presents a functional block diagram sum- 
mary of the supplemental logic necessary to support 
Off-Board memory expansion. Shaded blocks represent 
logic available with the basic MEK/D2 system. This 
convention holds for all schematics and diagrams in 
this note. 

Certain static RAMs require up to 1 00 ns of data hold 
following chip deselect. The 10 ns data hold specified 
for the MC6800 MPU is insufficient to meet this require- 
ment. The data bus enable (DBE) stretch network shown 
must be added if this type of RAM is utilized in the Off- 
Board expansion array. The Memory Control Handshake 
Logic provides control and timing signals between logic 
resident on Off-Board memory systems and the MPU 
clock module. Data transceivers, with a control logic 
block, are required to buffer bidirectional data to the 
Off-Board memory array as shown. The block labled 
"Array Select Decoder" represents logic for converting 
high-order address decode signals to Memory-Block 
enabling signals. These activitate either the On-Board or 
Off-Board array within the appropriate addressing range 
of a memory reference instruction. 

Logic Design 

Figure 3 shows a network which exploits the propaga- 
tion delay of non-inverting CMOS buffers to generate a 
"stretched" 02 for processor and peripheral- data bus 
enable. This network delays the falling edge of DBES 
approximately 125 ns with respect to DBE. This meets 
the data hold time requirement of most static RAMs. 
Trim capacitor Ct may be added for fine adjustments to 
account for device variations in accordance with the 
equation shown. 

Memory Control Handshake Logic is shown in Figure 
4. Clocked latches E17A and E17B provide signals to 
control either dynamic memory refresh or slow-memory 
access on a synchronous basis with respect to MPU 
timing. 
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FIGURE 1 - MEK6800D2 Block Diagram 
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FIGURE 2 — MEK/D2 Memory Expansion Logic Block Diagram 
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Dynamic memory cells store data in the form of 
electronic charge on the capacitance inherent in MOS 
transistor junctions. This charge must be periodically 
"refreshed." This is accomplished in most dynamic 
memories by performing a "dummy" read or write 
operation on each cell. In the case of the 8K Dynamic 
RAM Module (MEX6815-3), complete memory refresh 
is accomplished by a modified internal read operation 
on each of 32 columns once every 64 us. (memory 



system organization is 128 rows X 32 columns). The 
columns are accessed by an address multiplexer which is 
pulsed by the Refresh Grant (RG) handshake signal once 
every 64 fjs. 

The power-up reset network, composed of E9 and 
E4D, sets latch E17A on power-up to insure a proper 
initialization of the refresh-handshake logic. E9 also 
automatically initializes the MPU system on power-up 
by pulsing E6/12. 
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FIGURE 4 - Memory Control Handshake Logic 
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Figure 5 presents an example of refresh-handshake 
timing between latch E17A and logic on a dynamic 
memory system. The latch is clocked by AND-gate 
output Ca- The first low-to-high transistion of Ca (pulse 
1) following time-out of the refresh-period one-shot 
(8602) samples the logical zero state appearing at the D 
input of E17A. This state and its complement are trans- 
ferred by the rising edge of Ca to the Q and Q outputs 
of E17A as the signals Hold 1 and Refresh Grant (RG), 
respectively. The resultant falling edge of RG retriggers 



the 8602 to start a new timing cycle as shown in the 
diagram. This action returns the Request Refresh (RR) 
signal to logical one. This is sampled by the low-to-high 
transition of Ca, which returns Hold 1 high. The result- 
ing Hold 1 signal applied to the HI input of the MPU 
clock module is correctly phased to meet HI set-up and 
release time requirements and "freezes" the MPU clock 
in the phase relation shown. The resulting RG pulse 
automatically increments the refresh address counter for 
the next refresh cycle. 
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Figure 6 presents a typical example of slow memory 
control with handshake-timing between latch E17B and 
memory control logic on a slow memory board. Slow 
memory control signals are required to account for 
memories (or peripherals) whose access times are in the 
range of 540 to 4500 ns. The control signals provide 
proper slow memory data acquisition by freezing the 
MPU clock. This effectively allows the MPU to "wait" 
for memory data to return and still meet the maximum 
MPU bus memory access time specification of 540 ns. 
The access time upper limit of 4500 ns is determined by 
the maximum allowable clock phase 2 high time of 4500 
ns. High times in excess of this value will introduce data 
loss within the MPU dynamic registers. These registers 
use the MPU clock for refresh, just as with memory cells 
in dynamic RAM. The sequence of events for a slow 
memory access are described in trie waveform timing 
diagram. The array decoder output, AS, goes high fol- 
lowing the low-to-high transition of 02 for a memory 
reference within the addressing range of the array. The 
high-state of AS (or Slo Mem Acc) applied to the 
asynchronous-set input of latch E17B releases the 
hold-set condition on the latch and allows it to be 
clocked by the first Cb pulse. This forces Hold 2 (Q) 
low, which freezes the MPU clock in the phase relation 
shown. Hold 2 is returned high with the low-to-high 



transition of the next Cb pulse, since latch E17B is 
connected as a toggle flip-flop. Since Hold 2 is returned 
to logic 1 , the clock is allowed to resume as shown, and 
the cycle is complete. The resulting freeze of the clock 
cycle with 02 high and 01 low adds a 1 -clock-cycle delay 
to the normal access time available. This scheme may be 
extended with additional counters and logic in place of 
the toggle flip-flop to hold the clock a multiple-number 
of MEM Clk cycles for very slow memories. The total 
hold time must not exceed the 4500 ns maximum limit. 

A key integrated circuit for generating system bus 
chip-select or enabling signals in the MEK/D2 is the 
high-order address decoder Ull — a 2-line to 4-line 
decoder/demultiplexer. This logic element decodes the 
three-most-significant bits, A15-A13, of the address bus' 
in accordance with the following truth table. 
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FIGURE 6 - Slow Memory Handshake Logic and Waveforms 
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This scheme divides the 64K addressing range of the 
MPU into eight 8K blocks. The 512 byte static RAM 
array is placed in the bottom 8K range, the next two 8K 
blocks are reserved for expansion RAM, the fourth con- 
tains a user PROM, etc. 

Figure 7 presents the Bus Peripheral Allocation Map 
for the basic MEK/D2 system. Exact address boundaries 
of the bus peripherals described in the decoder truth 
table are defined in this map. The decoder output terms 
which enable the first three 8K blocks of memory, 
beginning with address zero, are RAM, 2/3 and 4/5. In- 
spection of the map shows that within the first address- 
able 8K block, only 512 bytes are dedicated to static 
RAM. This produces a memory addressing "gap" in the 
range 0200 to 1FFF as far as continuous addressing 
within the first 8K block is concerned. This problem 
may be solved by additional decoding of the three RAM 
select signals above so as to place an 8K expansion RAM 
in the first 8K addressing block, or a 16K expansion 
RAM within the first two 8K addressing blocks. The 512 
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FIGURE 8 — Addressing for 8.5K Memory Configuration 
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byte static array is then placed in either the second or 
third block, respectively, "on top" of the expansion 
RAM. Figures 8 and 9 show the additional decode re- 
quired to form either an 8.5K or 16.5K memory con- 
figuration. Control and Timing signals necessary to 
support these arrays are also shown. 

Data flow direction to Off-Board memory is deter- 
mined by the decode/control logic shown in Figure 10. 
This logic asserts DBRE (Data Bus Receive Enable) for 
any MPU read cycle involving Off-Board memory. This 
enabling scheme should be used with any additional 
Off-Board memory, whether static or dynamic. 

Recent developments in semiconductor dynamic 
RAM system design have provided compact, cost- 
effective arrays such as the MMS68100 and MMS68103 
produced by Motorola Memory Systems. These are avail- 
able in 4K x 8, 8K x 8, or 16K x 8 size. The most 
notable feature of these memories is that the usual 
refresh-handshake logic, such as shown in Figure 4, is 
not required since refresh is processed by memory board 
logic during MPU phase 1 . 



I/O DATA PORT EXPANSION/MODIFICATION 
Dual Monitor System - Functional Description 

The basic MEK/D2 system with keyboard data entry 
and seven-segment light-emitting-diode display may be 
expanded to include a co-resident data terminal I/O 
capability which may be evoked manually or from user 
program. The software necessary to support data 
terminal operations is provided in firmware using a 
MINIBUG ROM. This ROM monitor co-resides with the 
JBUG monitor ROM supplied with the basic MEK/D2. 
ROM access and initialization is controlled by the logic 
shown in functional block diagram form in Figure 11. 
With this scheme, peripheral chip-select signals derived 
from the high -order address decoder (Ull) are steered 
to the desired ROM-ACIA pair as a function of the state 
of the Chip Select Control signal, CSC. CSC is generated 
from either the manual ROM select switch (Sr) or by 
user-program command from the PIA. Control from user 
program automatically overrides the manual input but 
does not initiate an MPU reset cycle as does a manual 
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FIGURE 9 - Addressing for 16.5K Memory Configuration 
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select from Sr. With Sr in position J (for JBUG enable), 
the ROM and I/O chip-select signals (ROM and I/O are 
steered, respectively, only to the JBUG ROM or ACIA, 
while the MINIBUG ROM and ACIA are held deselected. 
The converse actions occur for Sr at position M (for 
MINIBUG enable). Each toggle of Sr generates an MPU 
Reset pulse via the State Change Detect Logic. This has 
the effect of automatically initializing each monitor 
ROM when manually selected. Nine standard data 
terminal baud rates may be derived from existing 
MEK/D2 logic and are used to provide transmit and 
receive clocks for the MINIBUG ACIA. 
Logic Design 

Logic realizations of the system functions depicted in 
Figure 1 1 are presented in Figures 12, 14, 15, 16 and 17. 



Figure 12 shows the Chip Select Steering Logic, MPU 
Cycle-Sync Logic and State Change Detect Logic. Chip- 
select steering is accomplished by the network composed 
of gates E5 and E1C. The clocked-latch network (E3A — 
E3B) which generates the chip-select steering control 
signal, provides two design benefits. First, monitor 
switching occurs only after MPU reset is asserted and 
prior to a 02 cycle, thus assuring that data will not be 
erroneously written or read as a result of a manual 
monitor select. In addition, latch E3 A, under the control 
of the PIA, provides an asynchronous-override to the 
manual select switch control. This feature allows direct 
access to subroutines in either ROM or addresses in 
either ACIA from the user program. A subroutine to 
accomplish this access is described in a following section. 
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Figure 13 shows the chip-select timing for a manual 
command conversion from JBUG to MINIBUG via 
toggle switch Sr. Exclusive-OR gates E6 in Figure 12 
form the state-change detection circuit which generates 
a 4 ms reset pulse for automatic MPU initialization 
whenever the monitor select switch is thrown in either 
direction. Note that provision for direct push-button 
reset of the MPU is also retained via E6D to pin 
6ofU22. 

Figure 14 shows address, data and control signal 
interconnection to the MINIBUG ROM and its ACIA. 
Note that even though these peripherals reside at the 
same bus address as the JBUG pair, the two pairs are 
never simultaneously selected due to the complemen- 
tary" control nature of the chip select steering logic. 

Figures 15 and 16 show circuitry necessary for inter- 
facing with data terminals using either RS-232 or 
current-loop I/O configuration. Data terminal baud- 
rate clocks may be taken from the existing MCI 4040 
binary counter (U17) outputs as shown in Figure 17. 
An MCI 455 connected as an astable multivibrator 
(El 3) is utilized to generate a baud-rate clock consistent 
with current-loop TTYs. 



Software Control Considerations 

Software access to addresses in either Monitor 
ROM or ACIA is gained through a subroutine which 
controls the output states of PBO and PB1 of the user 
PIA. The four possible states of PBO -PB1 produce the 
following control functions with respect to latch E3A, 
Figure 12: 
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grammed as inputs (all registers cleared). PBO - PB1 
appear as high-impedance inputs and both terms are held 
at logic 1 by the 10 kSl pullup resistors. 
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FIGURE 13 - Monitor Chip-Select Timing - Manual Select 
Select MINIBUG, Deselect JBUG 
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FIGURE 14 - MINIBUG Support Peripheral Addressing 
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FIGURE 15 - Terminal Interface Logic 
RS-232 Channel 
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FIGURE 16 — Terminal Interface Logic 
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FIGURE 17 - Baud Rate Logic 
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Chip Select Modifications for MIKBUG ROM 
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FIGURE 18 - Terminal Interface Logic for MIKBUG 
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Data Terminal-Only Configurations 

A configuration which employs data-terminal com- 
munication interface only may be easily implemented by 
inserting MINIBUG or MIKBUG Monitor ROMs into the 
JBUG ROM socket (U8). Foil path modifications and 
additional logic necessary to support these ROMs are as 
follows: 

Modifications for MINIBUG 

1. Cut foil path at U17, pin 13. 

2. Connect pins 3 and 4 of U23 (ACIA for Audio 
Cassette). 

3. Add terminal I/O interface logic as shown by 
Figures 15 or 16 and Figure 17. Connect U17 out- 
put to pin 3 or 4 of U23 as shown. U17/3 need not 
be cut (as shown in Figure 17) if 300 baud opera- 
tion is desired. 

Modifications for MIKBUG 

1. Add terminal I/O interface logic to the user PIA 
(U20) as described by the schematic of Figure 18. 

2. Cut foil paths at U8/10 and U8/11 and connect 
per Figure 18. 

The I/O logic and discrete components described in 
these figures may be mounted in the wire-wrap area pro- 
vided on the microcomputer module board. 

SYSTEM APPLICATION CONSIDERATIONS 

A subroutine which controls the monitor-selection 
latch (E3, Figure 12) through the PIA is presented in 
Figure 19. User program access to subroutines in ROM 
or addresses in ACIA is accomplished by first calling the 
monitor access subroutine (MONACC) shown in Figure 
19 and then executing a memory reference instruction 
to the ROM or ACIA address desired. As an example, 
the subroutine calling sequence: 

. 

LDAA # $ 41 Form ASCII "A" 
LDAB # $ 01 Get subroutine constant 
JSR MONACC Enable MINIBUG ROM/ 

ACIA addressing 
JSR $ El 08 Output ASCII char to 

terminal 



causes the character "A" to be printed on a terminal as 
a result of MINIBUG monitor access from the subrou- 
tine MONACC. In this example, the hex address E108 is 
the start vector of the MINIBUG II subroutine OUTCH 
which outputs one ASCII character to a terminal. The 
following is a list of useful data-moving subroutines con- 
tained in MINIBUG II and III along with their starting 
addresses, entry and exit conditions: 

* $ is Motorola Resident Assembler syntax for a hexadecimal 
number. 



MINIBUG ROUTINES 

( ) - Addresses in MINIBUG II 
< > -Addresses in MINIBUG HI 

BADDR (SE0D9) <$E0F8>* - Build a 16-bit hexa- 
decimal address from four digits entered from the 
keyboard. 

Entry requirements: none 

Exit: X-register contains the 16-bit address. The A& 
B registers are destroyed. 

BYTE ($E0E7) <$E106> - Input two hex characters 
from the keyboard and form a 1-byte number. 
Entry requirements: none 

Exit: A-register contains the 8-bit number. B-register 
is destroyed. 

OUTHL (SEOFA) <$E118> - Output left digit of hex 
number to console. 

Entry requirements: A-register contains hex number. 
Exit: A-register is destroyed. 

OUTHR (SEOFE) <E1 1C> - Output right digit of hex 
number to console. 

Entry requirements: A-register contains hex number. 
Exit: A-register is destroyed. 

OUTCH (SE108) ($E126> - Output one ASCII character 
to terminal. 

Entry requirements: A-register contains ASCII char- 
acter to output. 
Exit: No change 

INCHP ($E1 15) ($133) - Input one character, with 
parity, from terminal to A-register. 
Entry requirements: None 
Exit: A-register contains character input. 

INCH (SE11F) <$E133> - Input one character from 
terminal to A-register and set parity bit = 0. If char- 
acter is a delete ($7F) it is ignored. Location $A00C 
should be equal to zero if the character should be 
echoed (MINIBUG II only). 
Entry requirements: none 

Exit: A-register contains character without parity. 

PDATA1 (SE130) <$E14B> - Print at terminal the 
ASCII data string pointed to by X-register. Data 
string must contain an ASCII EOT ($04) as a 
terminator. 

Entry requirements: X-register contains the address 
of the 1st byte of the data string. The data string 
is terminated with a $04 character. 

Exit: A-register is destroyed. X-register contains 
address of $04 character. 

OUT2H ($E173) <$E18D> - Output two hex characters, 
pointed to by X-register to the terminal. 
Entry requirements: X-register contains the address 

of the characters to be output. 
Exit: A-register is destroyed. X-register is incre- 
mented. 



0UT2HA (SE175) <$E10F> - Output two hex char- 
acter in A-register to the terminal. 
Entry requirements: A-register contains the char- 
acters to output. 
Exit: A-register is destroyed. X-register is incre- 
mented. 

OUT4HS ($E17C) ($E196> - Output four hex char- 
acters (2 bytes) plus a space to the terminal. 
Entry requirements: X-register contains address of 
first byte. 

Exit: A-register is destroyed. X-register contains 
address of second byte. 
OUT2HS (SE17E) <$E198> - Output two hex char- 
acters (1 byte) and a space to the terminal. 
Entry requirements: X-register contains address of 

byte to output. 
Exit: A-register is destroyed. X-register is incre- 
mented. 



OUTS ($E180) <$E19A>- Output a space. 
Entry requirements: none 
Exit: A-register destroyed. 

The ability to gain access to two co-residing monitor 
ROMs via manual or software commands combined with 
keyboard, audio cassette, or data terminal I/O capability 
provides opportunity for moving program data between 
various storage media. It is possible, Tor instance, to 
create and assemble a program under the control of 
MINIBUG II or III using an RS-232-compatible digital 
cassette terminal. The resulting object code is loaded to 
MEK/D2 RAM using the MINIBUG "L" command. The 
Monitor Control Switch may now be used to initialize 
the JBUG Monitor in order to move the object code in 
RAM to an audio cassette tape with a JBUG "P" 
command. 
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FIGURE 19 — ROM Access Subroutine 



* $ is Motorola Resident Assembler syntax for a hexadecimal 
number. 18 



Figure 20 presents a tabular comparison of command 
sets for JBUG, MINIBUG and MIKBUG monitors. Any 
two pairs of these monitors may be used to configure 
the MEK/D2 computer to maximum advantage to suit 
the application through use of the dual monitor access 
logic described in Figure 12. A comparison of the com- 



mands of Figure 20 reveals that an excellent combina- 
tion might be a MINIBUG II/MINIBUG III configura- 
tion. This would provide capability for memory test, 
punching and loading of binary tapes as well as access to 
the powerful software edit functions of Trace and Break- 
point insertion. 



Monitor Function JBUG MINIBUG II MINIBUG III MIKBUG Notes 

Display Internal Registers R R R R 1 

Load RAM from Tape l_ L L L 

Dump RAM to Tape (Punch) P P P P 2 

Memory Examine/Change MM M M 3 

Go to Entered Address and Execute G G G G 4 

Set Terminal Baud Rate — S S - S 

Test Memory — W - - 6 

Punch Binary Tape from RAM — Y — — 7 

Load Binary Tape to RAM — 2 — — 7 

Abort Program Execution (Escape) E — — — 

Trace One Instruction N — N — 

Set a Breakpoint V — V — 8 

Reset a Breakpoint V — U — 

Continue Execute from Breakpoint E, G — C — 

Delete All Breakpoints V - D 8 

Print Addresses of All Breakpoints — — B — 

Trace N Instructions — — T — 



NOTES 

1. Order of Display: JBUG (PC,X,A,B,CC,SP); MINIBUG II and III, MIKBUG (PC,SP,CC,B,A,X). 

2. Before executing, load beginning and ending address of range in locations A002 to A005. 

3. For JBUG: Enter address, type M for contents. For MINIBUG: Enter M followed by address. Contents are 
displayed after typing last address character. For MIKBUG: Enter M, space, address. Address and data are 
printed. 

4. For JBUG: Enter starting address, type G. For MINIBUG: Type G, followed by address. Execution begins 
after type of last character. For MIKBUG: Load start address in A048/A049, type G. 

5. For 110 Baud: Type S1 . For 300 Baud: Type S3. 

6. Performs six memory tests: walking address, write/read all ones, all zeros, AA, 55 and "Walking Bit." 

7. Data is in binary (not ASCII) format. Requires a terminal with DC2, DC4 character recognition. 

8. For JBUG: Type address where breakpoint is desired, followed by V. A total of five may be entered. Re- 
moval of all breakpoints executed by typing V not preceded by address. For MINIBUG III: Same asJBUG 
except eight breakpoints may be entered. 

9. IRQ vector must be stored at A00O/A0O1, NMl must be stored at A006/A007 for all monitors. 



FIGURE 20 — Comparison of Monitor Commands 



Figure 21 presents a brief test program for evaluating 
user-program access to monitor subroutines through the 
monitor switching logic. The program should be exe- 
cuted from JBUG, i.e. with the monitor select switch in 
the J-poisition. Upon execution, MINIBUG addressing 
is enabled and a string of control characters are trans- 
mitted to the terminal. Following this, any character 
typed at the terminal is echoed to the terminal. When 
the character "ESC" is typed, the program jumps from 



the echo loop, JBUG addressing is software enabled and 
program control passes from the user program to the 
JBUG monitor. This action may be checked by viewing 
the dash "prompt" in the keyboard LED display im- 
mediately after typing the "ESC" character on the 
terminal keyboard. 

The W command of MINIBUG II may be used to test 
all memory in the expanded system. Figure 20 describes 
the use of this command. 



19 





















00001 








NRM 




TEST 1 






0000c! 








□PT 




D-S 






00003 


















00004 






♦ 


TEST PROGRAM TO EVRLURTE SOFTWARE ACCESS TO 


000 05 








■JBUG AND 


MINI BUG S 


JBROUT I NES THROUGH MONITDR 


000 06 






♦ 


SWITCHING 


LOGIC. TERMINAL 


IS 300 BAUBj RS-232 


000 07 








CONFIGURED. 


PROGRAM BOES MINI BUG ABBRESS 


00008 






♦ 


ENABLE? EXECUTES CI 


? + 4LF 


S AT TERMINAL- 


000 09 








THEN JUMF 




TO A CHARACTER 


ECHO MOBE. EACH 


1 






* 


CHARACTER 


TYPEB AT 


THE TERMINAL IS ECHOED 


on rn i 








ANB PRINTEI 


AT THE 


TERMINAL. WHEN AN "ESC" 


o o n i p 








IS TYPED* 


THE PROGRAM JUMPS OUT OF THE ECHO 


l"l f| f| \ 








LOOP ANB 


ENABLES JBUG MONITOR ABBRESS: I NG . 


1 4 








CONTROL I 




PASSEB 


ID THE JBUG MONITDR. THIS 


I'l f 1 1 "5 








ACTION MAY 


BE VIEWED BY OBSERVING THE JBUG 


1 6 






♦ 


"PROMPT" 


<A 


iiash> 


UN THE MEK-D2 KEYBOARD 


017 






♦ 


B I SPLAY IMMEDIATELY FOLLOWING TYPE OF THE 


1 8 






♦ 


"ESC" ON 


THE TERMINAL. THE PROGRAM IS INITIATED 


f 1 f 1 1 "3 

■j (_i 1.1 x 






♦ 


FROM JBUG 


WITH THE 


"6" COMMANB. 


02 






♦ 












00 021 




80 04 


IDBBR EQU 




$8004 






00 022 




80 06 


IODBB EQU 




S3 006 






00 023 




80 05 


CRR EQU 




$8005 






00024 




8 07 


CRB EQU 




$8007 






00025 




8 08 


RC 


I AC EQU 




$8 08 






ooo?6 




ft O^i 


RCIRB EQU 




$8 09 






(10 OP 7 

IJ i_i «_i C_ 1 


4 






ORG 




$4 00 






00 OPS 


4 


f E 4 1 FF 




LUX 




<s$41FF 




OOOftCi 


4 3 


01 




NOP 










fl fl 1*1 3 fl 


4 04 


OF 




SEI 










00 031 


4 05 


C6 1 




LDA 


B 


"$ 1 


GET MINI BUG ENABLE CONSTANT 


00032 


4007 


BB 4 0:-:R 




•JSR 




MONACO 


ENABLE MINI BUG ABBRESS I NG 


033 


4 OR 


86 03 




LDA 


A 


"$ 03 






034 


4 OC 


B7 80 OS 




ST A 


A 


AC I AC 


CLEAR AC I A 


00035 


4 OF 


86 09 




LDA 


A 


"$09 


7BITS? EVN PRTY ,1 STOP , / 1 6 


00 036 


4011 


B7 80 0ft 




STA 


A 


AC I AC 


CONFIGURE AC I A 


00037 


4014 


86 OB 




LDA 


A 


"$0B 






00038 


4016 


5F 




CLR 


B 








00039 


4017 


BB El 08 




•JSR 




$E108 


KM IT 


CR 


00040 


401R 


86 OR 




LDA 


A 


-$0A 






00041 


40 1C 


BB El 08 


Kl .JSR 




$E 1 08 


KM IT 


LF 


00 042 


401F 


5C 




INC 


B 








00043 


4 020 


CI 04 




CMP 


B 


«$04 


4 LF 


S ? 



FIGURE 21 - Test Program 
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FIGURE 21 (Continued) - Test Program 
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SUMMARY OF MODIFICATIONS 

A summary of foil-path modifications which account 
for both memory expansion and inclusion of multiple- 
monitor logic is tabulated in Figure 22. 



Figure 23 presents a tabular summary of additional 
power supply capability required to support the expan- 
sion logic and memory. Data from this table may be 
used to estimate requirements for a specific system 
configuration. 
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•For system with 16. 5K memory only. For 8.5K system, connect A 
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FIGURE 22 - MEK/D2 Foil Path Modification 



EXPANSION LOGIC 
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E6 


MC14507 


0.008 


12 


E7 


74LS133 


1.1 


10 


E9 


MC1455 


6.0 


4 


E11 


MC6830 


130.0 


14 


E12 


MC6850 


105.0 


14, 15, 16 


E13 


MC1455 


6.0 


17 


E14 


MC1488 


25 ( + 12 V), 15 (-12 V) 


15 


E15 


MC1489 


26.0 


15, 16 


E16 


MC8T96 


89.0 


16 


E17 


74LS74 


8.0 


4 


E18 


4N33 


10.7 (+5 V), 80 (+12 V) 


16 


E19 


4N33 


20.0 (+12 V) 


16 


E20 


4N33 


10.7 ( + 5 V), 20 (+12 V) 


16 


E21 


MC14503 


0.004 


3 


E22 


74LS08 


8.8 


4, 6 


E23 


74LS86 


10.0 


9 



EXPANSION MEMORY ARRAYS 





Worst -Case Supply Currents ImAI 


Architecture 


Type 


Motorola Part 


+5V 


+12 V 


-5 V 


-12 V 


2k x 8 


Static 


MEX6812-1 


1000 








8k x 8 


Dynamic 


MEX6815-1 


860 


300 






16k x 8 


Dynamic 


MMS68100* 


1200 


333 


4 




16k x 8 


Dynamic 


MMS68103 


1200 


333 




1.7 



•Not board-geometry compatible with EXORciser. 



FIGURE 23 — DC Power Supply Requirements for 
MEK/D2 Expansion 
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CONCLUSION 

The technqiues discussed in this note add the follow- 
ing capability to the basic MEK/D2 kit microcomputer 

* Power-up auto-reset 

* Switch-selectable monitor operation 

* RS-232 or current-loop data terminal operation at 
all standard baud-rates 

* RAM expansion to 16.5K bytes 

* ROM-resident subroutine acquisition by user 
program 

* Operation with JBUG, MINIBUG II and III or 
MINIBUG ROM monitors 
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